package cloudInformation.mapper;

import cloudEntity.vo.news.SmartNewsVO;
import org.apache.ibatis.annotations.Mapper;
import org.apache.ibatis.annotations.Param;

import java.util.List;

/**
 * 智慧校园新闻表(SmartNews)表数据库访问层
 *
 * @author makejava
 * @since 2025-04-13 20:44:20
 */
@Mapper
public interface SmartNewsMapper {

    /**
     * 根据 type 获取新闻信息
     * @param type 类型
     * @return 返回新闻信息
     */
    List<SmartNewsVO> GetNewsByType(@Param("type") Integer type,
                                    @Param("pageNum") Integer pageNum,
                                    @Param("pageSize") Integer pageSize);

    /**
     * 获取 新闻 总条数
     * @return 返回 新闻 总条数
     */
    Integer GetNewsCount(@Param("query") Integer query);

    /**
     * 修改新闻详情
     * @param sysNewsId 新闻id
     * @param sysNewsDescription 新闻详情
     * @param sysNewsPic 新闻图片url
     * @return
     */
    Integer UpdateNewsDetails(@Param("sysNewsId") Long sysNewsId,
                              @Param("sysNewsDescription") String sysNewsDescription,
                              @Param("sysNewsPic") String sysNewsPic);

    /**
     * 根据id删除新闻
     * @param ids 新闻id
     * @return 返回删除是否成功
     */
    Integer deleteNewsByIds(@Param("ids") Long ids);

    /**
     * 导出新闻 数据
     * @param type 新闻类型
     * @return 返回 新闻数据
     */
    List<SmartNewsVO> GetNewsDataExport(@Param("type") Integer type);

    /**
     * 新增 新闻 数据
     * @param sysNewsTitle 标题
     * @param sysNewsDescription 描述
     * @param sysNewsPic 图片 url
     * @param sysNewsType 类型
     * @return 返回 新增是否 成功
     */
    Integer InsertNewsData(@Param("sysNewsTitle") String sysNewsTitle,
                           @Param("sysNewsDescription") String sysNewsDescription,
                           @Param("sysNewsPic") String sysNewsPic,
                           @Param("sysNewsType") Integer sysNewsType);
}

